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NEAREST NEIGHBOR RECOMMENDATION 
METHOD AND SYSTEM 

5 

BACKGROUND OF THE INVENTION 

1 . Field of the Invention 

The present invention relates to systems that employ an electronic 
10 program guide to assist a media user in managing a large number of 

media-content choices (e.g., television programming, chatrooms, on-demand 
video media files, audio, etc.). The present invention more specifically relates to 
systems having the "intelligence" to suggest choices to a user and to take actions 
based on the suggestions (e.g., record a program on behalf of the user). 

15 

2. Description of the Related Art 

As the number of channels available to television viewers has increased, 
along with the diversity of the programming content available on such channels, it 
has become increasingly challenging for television viewers to identify television 

20 programs of interest. Historically, television viewers identified television 

programs of interest by analyzing printed television program guides. Typically, 
such printed television program guides contained grids listing the available 
television programs by time and date, channel and title. As the number of 
television programs has increased, the ability to effectively identify desirable 

25 television programs using such printed guides has become impractical. 

More recently, television program guides have become available in an 
electronic format, often referred to as electronic program guides (EPGs). Like 
printed television program guides, EPGs contain grids listing the available 
television programs by time, date, channel and title. An EPG, however, allows 

30 television viewers to sort or search the available television programs in 
accordance with personalized preferences. In addition, EPGs allow for 
on-screen presentation of the available television programs. 
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While EPGs allow viewers to identify several desirable programs more 
efficiently than conventional printed guides, they suffer from a number of 
limitations, which if overcome, could further enhance the ability of viewers to 
5 identify desirable programs. For example, many viewers have a particular 

preference towards, or bias against, certain categories of programming, such as 
action-based programs, or sports programming. Thus, the viewer preferences 
can be applied to the EPG to obtain a set of recommended programs that may 
be of interest to a particular viewer. 

10 The ultimate goal in the design of a television program recommendation 

program is to achieve the best possible classification of programs. This objective 
led to a development of different classifiers modules such as a Bayesian 
classifier module and a decision tree classifier module. A Bayesian classifier 
module is parametric, and consequently, numerous assumptions have to be 

15 made about the programs. A decision tree classifier module involves intensive 
computations that tend to produce a large number of disjoint rules when the data 
is sparse. The present invention addresses these specific disadvantages of prior 
art classifiers modules for recommending programs. 
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SUMMARY OF THE INVENTION 

The present invention relates to a nearest neighbor recommendation 
method and system that overcomes the disadvantages associated with the prior 
5 art. Various aspects of the invention are novel, non-obvious, and provide various 
advantages. While the actual nature of the present invention covered herein can 
only be determined with reference to the claims appended hereto, certain 
features, which are characteristic of the embodiments disclosed herein, are 
described briefly as follows. 

1 0 One form of the present invention is a method for generating a 

recommendation of a program. First, a program record corresponding to a 
program is received. Second, a plurality of program records is retrieved from a 
database. Third, one of the retrieved programs records is determined as the 
nearest neighbor of the received program record. And, finally, a 

15 recommendation of the program is based on the retrieved program record 
qualifying as the nearest neighbor. 

A second form of the present invention is a computer system comprising a 
database and a module. The database stores a plurality of program records. 
The module is operable to determine one of the stored program records as a 

20 nearest neighbor of a program record received by the system. The module is 
further operable to generate a recommendation of the received program record 
based on the stored program record qualifying as the nearest neighbor. 

The foregoing forms and other forms, features and advantages of the 
present invention will become further apparent from the following detailed 

25 description of the presently preferred embodiments, read in conjunction with the 
accompanying drawings. The detailed description and drawings are merely 
illustrative of the present invention rather than limiting, the scope of the present 
invention being defined by the appended claims and equivalents thereof. 
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BRIEF DESCRIPTION OF THE DRAWINGS 

FIG. 1 is a schematic diagram of one embodiment in accordance with the 
present invention of an automated recommendation system; 
5 FIG. 2 is a block diagram of one embodiment in accordance with the 

present invention of a controller of the FIG. 1 system; 

FIG. 3 is a flow chart of a program record conversion routine in 
accordance with present invention; 

FIG. 4 is a flow chart of a single neighbor classification routine in 
1 0 accordance with present invention; 

FIG. 5 is a flow chart of a multiple neighbor classification routine in 
accordance with present invention; and 

FIG. 6 is a flow chart of a neighbor cluster classification routine in 
accordance with present invention. 

15 

DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS 

FIG. 1 illustrates an automated program recommendation system 10 for a 
user 1 1 . System 1 0 comprises a display device in the form of a conventional 
television 20 as well a computer 30. Computer 30 can be housed within 

20 television 20 or set apart from television 20 as shown. 

In the illustrated embodiment, computer 30 is equipped to receive program 
schedule data (e.g., an electronic program guide) from a server 16. Computer 30 
can optionally receive implicit profile data of other system 10 users from a server 
16. Computer 30 is further equipped to receive a video signal including program 

25 schedule data from a tuner 12 (e.g., a cable tuner or a satellite tuner). Computer 
30 is also equipped with an infrared port 32 to allow user 1 1 to select a program 
to be viewed via a remote control 15. For example, user 1 1 can utilize remote 
control 15 to highlight a desired selection from an electronic program guide 
displayed on television 20. Computer 30 can have access to a database 13 from 

30 which computer 30 can receive updated program schedule data. The access 
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can be accomplished by a telephone line connectable to an Internet service 
provider or some other suitable data connection. Computer 30 is further 
equipped with a disk drive 31 to upload program schedule data, profile data of 
5 user 1 1 , and profile data of other system 10 users via a removable storage media 
such as a disk 14. 

Computer 30 may be configured in any form for accepting structured 
inputs, processing the inputs in accordance with prescribed rules, and outputting 
the processing results to thereby control the display of television 20 as would 

10 occur to those having ordinary skill in the art. Computer 30 may therefore be 
comprised of digital circuitry, analog circuitry, or both. Also, computer 30 may 
therefore be programmable, a dedicated state machine, or a hybrid combination 
of programmable and dedicated hardware. 

FIG. 2 illustrates one embodiment of computer 30. In the illustrated 

1 5 embodiment, computer 30 includes a central processing unit (CPU) 33 

operatively coupled to a solid-state memory 34. CPU 33 can be from the Intel 
family of microprocessors, the Motorola family of microprocessors, or any other 
type of commercially available microprocessor. Memory 34 is a computer 
readable medium (e.g., a read-only memory, an erasable read-only memory, a 

20 random access memory, a compact disk, a floppy disk, a hard disk drive, and 
other known forms) that is electrically, magnetically, optically or chemically 
altered to contain computer readable code corresponding to program record 
module 37, a single neighbor module 38, a multiple neighbor module 39, and a 
neighbor cluster module 40. Additionally, memory 34 stores a viewer profile 

25 database 35 of user 1 1 (FIG. 1) and a viewing history database 36 of program 
records. To implement the computer readable code within memory 34, computer 
30 can additionally include any control clocks, interfaces, signal conditioners, 
filters, Analog-to-Digital (A/D) converters, Digital-to-Analog (D/A) converters, 
communication ports, or other types of operators as would occur to those having 

30 ordinary skill in the art. 
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In an alternative embodiment of computer 30, program record module 37, 
single neighbor module 38, multiple neighbor module 39, and/or neighbor cluster 
module 40 can be partially or fully implemented by digital circuitry, analog 
circuitry, or both such as, for example, an application specific integrated circuit 
(ASIC). Also in alternative embodiments of computer 30, program record module 
37, single neighbor module 38, multiple neighbor module 39, and/or neighbor 
cluster module 40 may be omitted. 

Program record module 37 implements a program record conversion 
routine 50 as shown in FIG. 3. During a stage S52 of routine 50, program record 
module 37 receives a program record PR1 . The following TABLE 1 exemplary 
illustrates program record PR1 including key fields and corresponding 
descriptions: 



15 



TABLE 1 



KEY FIELD 


DESCRIPTION 


$date 


yyyymmdd 


$air time 


hhmm from 0000-2359 


$station__sign 


4 characters 


$title 


120 characters 


$desc 


120 characters 


$genre 


20 characters 


$actors 


120 characters 


$directors 


120 characters 


$hosts 


120 characters 


$producers 


120 characters 


$writers 


120 characters 
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During a stage S54 of routine 50, program record engine 50 converts each 
relevant key field of program record PR1 into a feature value. The relevance of 
each key field is based on the incorporation of the key field within computations 
performed by modules 38-40 as will be further described herein. In one 
embodiment of stage S54, program record module 37 includes a listing of each 
relevant key field being divided into two or more partitions with each partition 
having a feature value assigned thereto. The following TABLE 2 exemplary 
illustrates a listing of key field partitions and corresponding feature values: 

TABLE 2 



KEY FIELD: PARTITION 


FEATURE VALUE 


$air_time: Morning (6am-12pm) 


1 


$air_time: Afternoon (1 2pm-6pm) 


2 


$air_time: Evening (6pm-12am) 


3 


$air_time: Night (12am-6pm) 


4 


$station_sign: NBC 


1 


$station_sign: ABC 


2 


$station_sign: CBS 


3 



$station 


_sign: 


TBS 


4 


$station 


_sign: 


TNT 


5 


$station_ 


_sign: 


USA 


6 


$station_ 


_sign: 


CNN 


7 


$station_ 


sign: 


ESPN 


8 


$station_ 


_sign: 


HBO 


9 


$station 


_sign: 


MTV 


10 



Accordingly, program record module 37 converts a key field $air_time of 
program record PR1 to a feature value of 3 and a key field $station_sign of 
1 5 program record PR1 to a feature value of 9 when the aforementioned key fields 
indicate the program corresponding to program record PR1 is on HBO between 
6pm and 12am. Program record module 37 terminates routine 50 upon 
completion of stage S54. 
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Single neighbor module 38 implements a single neighbor classification 
routine 60 as shown in FIG. 4. During a stage S62 of routine 60, single neighbor 
module 38 determines a distance between each feature value of program record 
5 PR1 to each related partition. In one embodiment of stage S62, single neighbor 
module 38 utilizes the following equation [1] during stage S62: 

i=i 

where 5 is the distance measurement, V? is the feature value of program record 
PR1 , V 2 \s the feature value of a related partition, n is a number of categories, Cn 

1 0 is the number of times V 1 was classified into category /, is the total number of 
times the feature value of program record PR1 has occurred, C 2/ * is the number of 
times V 2 was classified into category /, 2 1 is the total number of times the feature 
value of a related partition has occurred, and /Cis a constant such as, for 
example, 1 for Euclidean distance measurements and 2 for other types of 

15 distance measurements. 

The following TABLE 3 exemplary illustrates a number of positive counts 
and a number of negative counts of each partition of the key field $air_time while 
the following TABLE 4 exemplary illustrates distance measurements based upon 
equation [1] with K being 1: 

20 



TABLE 3 



KEY FIELD: PARTITION 


POSITIVE 
COUNTS 


NEGATIVE 
COUNTS 


$air_time: Morning (6am-12pm) 


45 


43 


$air_time: Afternoon (12pm-6pm) 


24 


56 


$air_time: Evening (6pm-12am) 


78 


20 


$air_time: Night (12am-6pm) 


27 


45 



c 2i 



[1] 
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TABLE 4 



MORNING AFTERNOON EVENING NIGHT 

evening — q-^— — - — - QQ 084 



The following TABLE 5 exemplary illustrates a number of positive counts 
and a number of negative counts for each partition of the key field $station_sign 
while the following TABLE 6 exemplary illustrates distance measurements based 
upon equation [1] with K being 1: 



TABLE 5 



KEY FIELD: PARTITION 




POSITIVE 
COUNTS 


NEGATIVE 
COUNTS 


$station_sign: NBC 




54 


54 


$station_sign: ABC 




45 


25 


$station_sign: CBS 




72 


42 


$station_sign: TBS 




24 


57 


$station_sign: TNT 




27 


15 


$station_sign: USA 




67 


34 


$station_sign: CNN 




45 


42 


$station_sign: ESPN 




77 


24 


$station_sign: HBO 




98 


45 


$station_sign: MTV 




54 


45 




TABLE 6 






NBC ABC CBS TBS 


TNT USA 


CNN ESPN 


HBO MTV 


HBO 0.37 0.08 0.10 0.77 


0.08 0.04 


0.33 0.15 


0.00 0.28 



Single neighbor module 38 thereafter proceeds to a stage S64 of routine 
60 to determine which stored program within viewing history 35 is the nearest 
neighbor to program record PR1 . In one embodiment of stage S64, a score is 
determined for each stored program record with the score being equal to a sum 
of each feature value of a stored program record. The following TABLE 7 
exemplary illustrates a score for twelve (12) stored programs within viewing 
history database 36: 
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TABLE 7 

STORED 



PROGRAM 


$air__time 


FEATURE 


$station_sign 


i — i — a ~r i i n l — 

FEATURE 




RECORD 


PARTITION 


\ / A 1 1 1 1 — 

VALUE 


r— > a nTlTIAM 

PARTITION 


VALUE 


bCUKb 


PR2 


Morning 


a 

0.56 


NBC 


U.O/ 


u.yo 


PR3 


Morning 


0.56 


ABC 


A AO 

0.08 


A CtA 

U.D4 


PR4 


Morning 


0.56 


CBo 


A A A 
0.1U 


U.oo 


rKO 


Auernoon 


n qq 


PMM 


u.oo 




PR6 


Afternoon 


0.99 


TBS 


0.77 


1.76 


PR7 


Afternoon 


0.99 


TNT 


0.08 


1.07 


PR8 


Evening 


0.00 


NBC 


0.37 


0.37 


PR9 


Evening 


0.00 


ABC 


0.08 


0.08 


PR10 


Evening 


0.00 


CBS 


0.10 


0.10 


PR11 


Night 


0.84 


HBO 


0.00 


0.84 


PR12 


Night 


0.84 


MTV 


0.28 


1.02 


PR13 


Night 


0.84 


USA 


0.04 


0.88 



From TABLE 7, program record PR9 qualifies as the nearest neighbor to 
5 program record PR1 with a score of 0.08. 

Singe neighbor module 38 thereafter proceeds to a stage S66 of routine 
60 to generate a program recommendation for program record PR1 based upon 
the nearest neighbor determined during stage S64. In one embodiment of stage 
S66, nearest neighbor module 38 compares the total positive count of the 
1 0 nearest neighbor to the total negative count of the nearest neighbor whereby 
program record PR1 is recommended if the total positive count is equal to or 
greater than the total negative count and whereby program record PR1 is not 
recommended if the total positive count is less than the total negative count. 
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The following TABLE 8 exemplary illustrates a comparison of the total 
positive count and the total negative count for program record PR9: 

TABLE 8 



POSITIVE NEGATIVE 
KEY FIELD: PARTITION COUNTS COUNTS 



$air_time: Evening 


78 


20 




$station_sign: ABC 


45 


25 






123 


45 


TOTALS 



5 

The total positive count of program record PR9 is greater than the total 



negative counts of program record PR9. Single neighbor module 38 therefore 
provides a program recommendation REC via television 20 (FIG. 1) to user 1 1 
(FIG. 1) corresponding to program record PR1. 

1 0 Single neighbor module 38 terminates routine 60 upon completion of 

stage S66. Those having ordinary skill in the art will appreciate a benefit of 
routine 60 is the simplicity in the calculations performed during routine 60 and the 
elimination of any assumptions. 

Multiple neighbor module 39 implements a multiple neighbor classification 

1 5 routine 70 as shown in FIG. 5. During a stage S72 of routine 70, multiple 
neighbor module 39 determines a distance between each feature value of 
program record PR1 to each related partition identically to the execution of stage 
S62 of routine 60 (FIG. 4) by single neighbor module 38 as previously described 
herein. During a stage S74 of routine 70, multiple neighbor module 39 

20 determines N number of stored program records within viewing history database 
36 that qualify as the N number of nearest neighbors to program record PR1 . 
While N can be any number greater than 1 , preferably, N is either 5, 7, or 9. In 
one embodiment of stage S74, multiple neighbor module 39 determines a score 
for each stored program record identically to the execution of stage S64 of 

25 routine 60 by single neighbor module 38. Multiple neighbor module 39 thereafter 
determines N number of nearest neighbors such as, for example, program 
records PR3, PR4, PR8, PR9 and PR10 from TABLE 7 when N is five (5). 
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During a stage S76 of routine 70, multiple neighbor module 39 generates 
a program recommendation for program record PR1 based upon N nearest 
neighbor determined during stage S74. In one embodiment of stage S76, 
multiple neighbor module 39 compares the total positive counts of the N nearest 
neighbors to the total negative count of the N nearest neighbors whereby 
program record PR1 is recommended if the total positive counts is equal to or 
greater than the total negative counts and whereby program record PR1 is not 
recommended if the total positive counts is less than the total negative counts. 

The following TABLE 9 exemplary illustrates a comparison of the total 
positive counts and the total negative counts for program records PR3, PR4, 
PR8, PR9 and PR10: 



TABLE 9 





POSITIVE 


NEGATIVE 


PROGRAM RECORD 


COUNTS 


COUNTS 


PR3 


90 


68 


PR4 


117 


85 


PR8 


132 


74 


PR9 


123 


45 


PR10 


150 


62 




612 


332 TOTALS 



The total positive counts of program records PR3, PR4, PR8, PR9 and 
PR10 is greater than the total negative counts of program records PR3, PR4, 
PR8, PR9 and PR10. Multiple neighbor module 39 therefore provides program 
recommendation REC via television 20 (FIG. 1) to user 1 1 (FIG. 1) 
corresponding to program record PR1. 

Multiple neighbor module 39 terminates routine 70 upon completion of 
stage S76. Those having ordinary skill in the art will appreciate a benefit of 
routine 70 is the simplicity in the calculations during routine 70 and the 
elimination of any assumptions. 
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Neighbor cluster module 40 implements a multiple neighbor classification 
routine 80 as shown in FIG. 6. During a stage S82 of routine 80, neighbor cluster 
module 40 determines a distance between each feature value of program record 
5 PR1 to each related partition identically to the execution of stage S62 of routine 
60 (FIG. 4) by single neighbor module 38 as previously described herein. 

During a stage S84 of routine 80, module 40 determines the nearest 
neighbor cluster to program record PR1 . In one embodiment of stage S84, 
neighbor cluster module 40 determines a score for each stored program record 

1 0 identically to the execution of stage S64 of routine 60 by module 38 as previously 
described herein. Neighbor cluster module 40 thereafter determines the nearest 
neighbor cluster based on the scores. In one embodiment of stage S84, the 
stored program records are formed in a watched cluster and a non-watched 
cluster with each cluster having an average score. The following TABLE 10 

1 5 exemplary illustrates a watched cluster of the twelve (12) stored programs within 
viewing history database 36: 

TABLE 10 

"stored 



PROGRAM 


$air time 


FEATURE 


$station sign 


FEATURE 




RECORD 


PARTITION 


VALUE 


PARTITION 


VALUE 


SCORE 


PR3 


Morning 


0.56 


ABC 


0.08 


0.64 


PR9 


Evening 


0.00 


ABC 


0.08 


0.08 


PR10 


Evening 


0.00 


CBS 


0.10 


0.10 


PR11 


Night 


0.84 


HBO 


0.00 


0.84 


PR13 


Night 


0.84 


USA 


0.04 


0.88 



20 
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An average score of the watched cluster is 0.50. The following TABLE 1 1 
exemplary illustrates a non-watched cluster of the twelve (12) stored programs 
within viewing history database 36: 

TABLE 11 

STORED 



PROGRAM 


$air time 


FEATURE 


$station sign 


FEATURE 




RECORD 


PARTITION 


VALUE 


PARTITION 


VALUE 


SCORE 


PR2 


Morning 


0.56 


NBC 


0.37 


0.93 


PR4 


Morning 


0.56 


CBS 


0.10 


0.66 


PR5 


Afternoon 


0.99 


CNN 


0.33 


1.32 


PR6 


Afternoon 


0.99 


TBS 


0.77 


1.76 


PR7 


Afternoon 


0.99 


TNT 


0.08 


1.07 


PR8 


Evening 


0.00 


NBC 


0.37 


0.37 


PR12 


Night 


0.84 


MTV 


0.28 


1.02 



An average score of the non-watched cluster is 1 .01 . 
In another embodiment of stage S84, the stored program records are 
10 formed into clusters based on the key field $genre, such as, for example, a movie 
cluster, a news cluster, a sports cluster, a sitcom cluster, a music video cluster, 
etc. The following TABLE 12 exemplary illustrates a news cluster of the twelve 
(12) stored programs within viewing history database 36: 

15 TABLE 12 



STORED 












PROGRAM 


$air time 


FEATURE 


$station sign 


FEATURE 




RECORD 


PARTITION 


VALUE 


PARTITION 


VALUE 


SCORE 


PR2 


Morning 


0.56 


NBC 


0.37 


0.93 


PR3 


Morning 


0.56 


ABC 


0.08 


0.64 


PR4 


Morning 


0.56 


CBS 


0.10 


0.66 


PR5 


Afternoon 


0.99 


CNN 


0.33 


1.32 
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An average score of the news cluster is 0.88. The following TABLE 1 3 
exemplary illustrates a movie cluster of the twelve (12) stored programs within 
viewing history database 36: 

5 

TABLE 13 

STORED 

PROGRAM $air_time FEATURE $station_sign FEATURE 



RECORD 


PARTITION 


VALUE 


PARTITION 


VALUE 


SCORE 


PR6 


Afternoon 


0.99 


TBS 


0.77 


1.76 


PR7 


Afternoon 


0.99 


TNT 


0.08 


1.07 


PR11 


Night 


0.84 


HBO 


0.00 


0.84 


PR13 


Night 


0.84 


USA 


0.04 


0.88 



An average score of the movie cluster is 1.13. The following TABLE 14 
exemplary illustrates a music video cluster of the twelve (12) stored programs 
10 within viewing history database 36: 



TABLE 14 

STORED 

PROGRAM $air_time FEATURE $station_sign FEATURE 
RECORD PARTITION VALUE PARTITION VALUE SCORE 
PR12 " Night 0.84 MTV 0 .28 1.02 

An average score of the music video cluster is 1 .02. 

1 5 Neighbor cluster module 40 thereafter proceeds to a stage S86 of routine 

80 to generate a program recommendation for program record PR1 based upon 
the nearest neighbor cluster determined during stage S84. In one embodiment 
of stage S86, neighbor cluster module 40 provides program recommendation 
REC via television 20 (FIG. 1 ) to user 1 1 (FIG. 1 ) corresponding to program 

20 record PR1 when the watched cluster is determined to be the nearest neighbor 
during stage S84. Conversely, neighbor cluster module 40 does not program 
recommendation REC via television 20 (FIG. 1) to user 1 1 (FIG. 1) 
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corresponding to program record PR1 when the non-watched cluster is 
determined to be the nearest neighbor during stage S84 

In another embodiment of stage S86, neighbor cluster module 40 
5 compares the total positive counts of the nearest neighbor cluster to the total 
negative counts of the nearest neighbor cluster whereby program record PR1 is 
recommended if the total positive counts is equal to or greater than the total 
negative counts and whereby program record PR1 is not recommended if the 
total positive counts is less than the total negative counts. For example, the 
1 0 watched cluster of TABLE 1 0 is a nearest neighbor cluster of program record 
PR1 . The following TABLE 15 exemplary illustrates a comparison of the total 
positive counts and the total negative counts for program records of the watched 
cluster of TABLE 10: 

15 TABLE 15 



STORED 


POSITIVE 


NEGATIVE 


PROGRAM RECORD 


COUNTS 


COUNTS 


PR3 


90 


68 


PR9 


123 


45 


PR10 


150 


62 


PR11 


125 


90 


PR13 


94 


79 




582 


344 TOTALS 



The total positive counts of the watched cluster is greater than the total 
negative counts of program records the watched cluster. Neighbor cluster 
module 40 therefore provides program recommendation REC via television 20 
20 (FIG. 1 ) to user 1 1 (FIG. 1 ) corresponding to program record PR1 . 
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Also by example, the news cluster of TABLE 12 is a nearest neighbor 
cluster of program record PR1 . The following TABLE 16 exemplary illustrates a 
comparison of the total positive counts and the total negative counts for program 
5 records of the news cluster of TABLE 1 6: 



TABLE 16 



STORED 


POSITIVE 


NEGATIVE 


PROGRAM RECORD 


COUNTS 


COUNTS 


PR2 


99 


97 


PR3 


90 


68 


PR4 


117 


85 


PR5 


69 


98 




375 


348 TOTALS 



The total positive counts of the news cluster is greater than the total 
10 negative counts of program records the news cluster. Neighbor cluster module 
40 therefore provides program recommendation REC via television 20 (FIG. 1) to 
user 1 1 (FIG. 1) corresponding to program record PR1 . 

Neighbor cluster module 40 terminates routine 80 upon completion of 
stage S86. Those having ordinary skill in the art will appreciate a benefit of 
15 routine 80 is the simplicity in the calculations during routine 80 and the 
elimination of any assumptions. 

It will be evident to those skilled in the art that the invention is not limited 
to the details of the foregoing illustrative embodiments, and that the present 
invention may be embodied in other specific forms without departing from the 
20 spirit or essential attributes thereof. The present embodiments are therefore to 
be considered in all respects as illustrative and not restrictive, the scope of the 
invention being indicated by the appended claims rather than by the foregoing 
description, and all changes which come within the meaning and range of 
equivalency of the claims are therefore intended to be embraced therein. 

25 
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